import java.util.Scanner;

/**
 * Created With IntelliJ IDEA
 * Description:牛客网: 首页 > 试题广场 > 分解因数
 * <a href="https://www.nowcoder.com/questionTerminal/0f6976af36324f8bab1ea61e9e826ef5">...</a>
 * User: DELL
 * Data: 2023-04-24
 * Time: 13:21
 */

/**
 * 本题较为简单,主要注意一下两点:
 * 1. 注意控制输出格式,这里使用了一个 isFirst 来标记是否是第一个因数,控制第一个因数的输出格式
 * 2. 一定要注意一个质数因子多次出现的情况,例如 20 = 2 * 2 * 5
 */
public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNext()) {
            int a = scanner.nextInt();
            if (isPrime(a)) {
                System.out.println(a + " = " + a);
                continue;
            }
            //控制输出用的
            boolean isFirst = true;
            for (int i = 2; i <= a; i++) {
                if (a % i == 0) {
                    if (isFirst) {
                        System.out.print(a + " = " + i);
                        isFirst = false;
                    } else {
                        System.out.print(" * " + i);
                    }
                    a /= i;
                    //这里让 i-- 是为了防止一个质数因子多次出现的情况,即再次判断一下这个 i 是否还是因子
                    i--;
                    if (isPrime(a)) {
                        System.out.print(" * " + a);
                        break;
                    }
                }
            }
            //换行
            System.out.println();
        }
    }

    private static boolean isPrime(int num) {
        if (num <= 3) {
            return true;
        }
        for (int i = 2; i*i <= num; i++) {
            if (num % i == 0) {
                return false;
            }
        }
        return true;
    }
}
